package sort;

/**
 * @author way
 * @create 2025-03-17 21:06
 */
public class SelectSort {
    /**
     * 选择排序:首先找到数组中最小的那个元素，然后将它和数组的第一个元素交换位置，
     * 之后在剩下的元素找到最小的元素，将它与数组第二个元素进行交换,如此往复。
     * 不断选择剩余元素中最小的元素
     */
   public void selectSort(int[] a, int len) {
        for (int i = 0; i < len; i++) {
            int min = i;
            for (int j = i + 1; j < len; ++j) {
                if (a[j] < a[min]) min = j;
            }
            swap(a, i, min);
        }
    }

    public void swap(int[] a, int i, int j) {
        int temp;
        temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }

    public static void main(String[] args) {
        int[] arr = new int[]{5,4,3,8,2,7,9,1};
        SelectSort sort = new SelectSort();
        sort.selectSort(arr,arr.length);
        for (int i : arr) {
            System.out.println(i);
        }
    }
}
